//给定一个排序的整数数组 nums 和一个整数目标值 target ，请在数组中找到 target ，并返回其下标。如果目标值不存在于数组中，返回它将会被按顺
//序插入的位置。 
//
// 请必须使用时间复杂度为 O(log n) 的算法。 
//
// 
//
// 示例 1： 
//
// 
//输入: nums = [1,3,5,6], target = 5
//输出: 2
// 
//
// 示例 2： 
//
// 
//输入: nums = [1,3,5,6], target = 2
//输出: 1
// 
//
// 示例 3： 
//
// 
//输入: nums = [1,3,5,6], target = 7
//输出: 4
// 
//
// 示例 4： 
//
// 
//输入: nums = [1,3,5,6], target = 0
//输出: 0
// 
//
// 示例 5： 
//
// 
//输入: nums = [1], target = 0
//输出: 0
// 
//
// 
//
// 提示： 
//
// 
// 1 <= nums.length <= 10⁴ 
// -10⁴ <= nums[i] <= 10⁴ 
// nums 为无重复元素的升序排列数组 
// -10⁴ <= target <= 10⁴ 
// 
//
// 
//
// 
// 注意：本题与主站 35 题相同： https://leetcode-cn.com/problems/search-insert-position/ 
//
// Related Topics 数组 二分查找 👍 57 👎 0


package LeetCode.editor.cn;


/**
 * @author ldltd
 * @date 2025-02-27 16:31:08
 * @description LCR 068.搜索插入位置
 
 */
 
public class N6YdxV {
    public static void main(String[] args) {
    //测试代码
    N6YdxV fun = new N6YdxV();
    Solution solution= fun.new Solution();
    solution.searchInsert(new int[]{1,3,5,6},2);
    }

//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public int searchInsert(int[] nums, int target) {
            int l=0,r=nums.length-1;
            int res=r+1;
            while (l<=r){
                int m=(l+r)/2;
                if(nums[m]>=target){
                    r=m-1;
                    res=m;
                }else {
                    l=m+1;
                }
            }
            return res;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
